草庐IT

c++ - 观察数据变化的不同方式

全部标签

ruby - 在 TextMate 中使用 RVM 和不同的 gemsets

我已经根据RVMbestpractices设置了RVM并为我的项目制作了单独的gemsets.现在在TextMate中运行测试文件不起作用,我有readhere该怎么办。问题是它不起作用,因为指南希望我只有一个gemset(他们称之为“Rails3”)。我通常一次打开2-3个项目(使用不同的gemsets),所以我不能有效地使用这种方法。你们有人解决过这个问题吗? 最佳答案 我发现RVM包装器方法有很多错误,而且正如您所发现的那样,除非您进行大量繁琐的设置,否则它根本不适用于gemsets。我使用以下脚本作为TM_RUBY取得了一些

ruby - ruby 和 irb 使用不同的模块搜索路径吗?

我有一个试图需要restclient模块的Ruby脚本。当我将它减少到只有这一行时,它仍然失败:#!/usr/bin/envrubyrequire'restclient'当我运行它时,出现以下错误:./test.rb:3:in`require':nosuchfiletoload--restclient(LoadError)from./test2.rb:3当我运行irb时,模块加载正常:$irb>>require"restclient"=>true>>据我所知,脚本和irb似乎都具有相同的模块路径:$ruby-e"puts$:"/Library/Ruby/Site/1.8/Library

ruby-on-rails - 有没有办法拥有多个 seeds.rb 文件?任何类型的 'versioning' 用于种子数据?

我们需要为一些新添加的表添加更多种子数据到我们的Rails项目的“版本100”。但是,如果我们简单地将它添加到seeds.rb中并重新运行rakedb:seed命令,它当然会重新添加原始种子数据,复制它。因此,如果您已经将种子数据添加到seeds.rb中,例如,TableOne...我们如何在开发的后期阶段为TableTwo和TableThree增量添加种子数据?我希望我可以简单地创建一个新的seeds_two.rb文件并运行rakedb:seeds_two但这给出了一个错误不知道如何构建任务“db:seeds_two”所以看起来只能使用“seeds.rb”。人们如何维护对种子数据的增

ruby-on-rails - 在 Rails 中是否有比 Observers 更直接的方式来执行发布/订阅模式?

我有一个模型依赖于一个单独的、联合的模型。classMagazine图像是多态的,可以附加到许多对象(页面和文章),而不仅仅是杂志。杂志需要在相关图像发生任何变化时自行更新该杂志还保存了一张自己的截图,可用于宣传:classMagazine现在如果图像发生变化,杂志也需要更新其截图。所以杂志真的需要知道图片什么时候出了问题。所以我们可以天真地直接从封面图片触发屏幕截图更新classImage...但是图片不应该代表杂志做事然而,图片可以用于许多不同的对象,实际上不应该对杂志进行特定的操作,因为这不是图片的责任。该图像也可能附加到页面或文章,并且不需要为它们做各种事情。“正常”的rail

sql - 如何获得不同的多态关联

我试图在没有任何重复的情况下显示多态关系列表。我有一个StoreViews表,其中包含一个名为viewable的多态字段(因此我的表中有一个viewable_id和viewable_type列)。现在我想显示View,每个多态关系只显示一次,没有重复。@views=StoreView..distinct(:viewable_id).distinct(:viewable_type).order("created_atDESC").limit(10)因此,如果StoreViews中有两条记录,并且都具有相同的可见关系,@views应该只返回最近的一条。然而,事实并非如此。

ruby-on-rails - 如何在 RoR 中上传文本文件并将内容解析到数据库中

到目前为止,我已经成功上传了一个文件:#Innew.html.erb并访问Controller中的文件#Incontroller#create@text=params[:upload][:file]但是,这给我的只是文件名,而不是文件的内容。如何访问其内容?我知道这是一个跳跃,但是一旦我可以访问文件的内容,是否可以上传文件夹并遍历文件? 最佳答案 完整示例以上传包含联系人的导入文件为例。您无需存储此导入文件,只需对其进行处理并丢弃即可。路线routes.rbresources:contactsdocollectiondoget'im

Ruby 的 ARGV 在 Windows 上可以为空,具体取决于运行脚本的方式

我的演示.rb:putsARGV.sizeARGV.eachdo|a|puts"Argument:#{a}"end结果取决于我们如何运行脚本:>demo.rbfoobar0>rubydemo.rbfoobar2Argument:fooArgument:bar为什么会这样?可以用这个做点什么吗?编辑:感谢所有回复!这是我的设置:>assoc.rb.rb=rbFile>ftyperbFilerbFile="c:\ruby-1.8.6\bin\ruby.exe""%1"%*所以看起来是对的。但是我发现了>demo.rbfoobar使用这样的命令行启动进程:"C:\ruby-1.8.7\bin

ruby-on-rails - 英雄数据库 :pull not working

herokudb:pullpostgresql://root:@localhost/db_name执行此命令后显示此消息/usr/lib/ruby/gems/1.8/gems/rest-client-1.6.1/lib/restclient/abstract_response.rb:50:警告:future版本的括号参数加载水龙头v0.3.13警告:数据库“postgresql://root:@localhost/db_name”中的数据将被覆盖并且无法恢复。您确定要继续吗?(是/否)?是连接数据库失败:Sequel::AdapterNotFound->LoadError:没有要加载的

ruby - 事件/观察者驱动的 Ruby on Rails

我有一个适用于事件/监听器模型的应用程序。发布了几种不同类型的数据(事件),然后许多不同的事情可能需要也可能不需要对该数据(监听器)采取行动。监听器的发生没有特定的顺序,每个监听器将决定是否需要对事件采取行动。Rails应用程序有哪些工具可以完成此任务?我希望自己不必这样做(尽管我可以。这没什么大不了的。)编辑:观察者模式可能是更好的选择 最佳答案 查看EventMachine.它是一个非常流行的Ruby事件处理库。它看起来相当不错,而且很多其他库似乎都在利用它(Cramp)。这是一个很好的介绍:http://rubylearnin

ruby - 如何在 heroku 中使用自己的 mysql 数据库服务器?

我想使用托管在我自己服务器上的mysql数据库。我已经更改了DATABASE_URL和SHARED_DATABASE_URL配置变量以指向我的服务器,但它仍在尝试连接到heroku的amazonaws服务器。我该如何解决? 最佳答案 根据Herokudocumentation,更改DATABASE_URL是正确的方法。Ifyouwouldliketohaveyourrailsapplicationconnecttoanon-Herokuprovideddatabase,youcantakeadvantageofthissamemec